package dynamic;

import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;

import java.util.Arrays;
/*
你是一个专业的小偷，计划偷窃沿街的房屋。每间房内都藏有一定的现金，影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统，如果两间相邻的房屋在同一晚上
被小偷闯入，系统会自动报警。

 给定一个代表每个房屋存放金额的非负整数数组，计算你 不触动警报装置的情况下 ，一夜之内能够偷窃到的最高金额。



 示例 1：


输入：[1,2,3,1]
输出：4
解释：偷窃 1 号房屋 (金额 = 1) ，然后偷窃 3 号房屋 (金额 = 3)。
     偷窃到的最高金额 = 1 + 3 = 4 。

 示例 2：


输入：[2,7,9,3,1]
输出：12
解释：偷窃 1 号房屋 (金额 = 2), 偷窃 3 号房屋 (金额 = 9)，接着偷窃 5 号房屋 (金额 = 1)。
     偷窃到的最高金额 = 2 + 9 + 1 = 12 。




 提示：


 1 <= nums.length <= 100
 0 <= nums[i] <= 400


 Related Topics 数组 动态规划 👍 2220 👎 0

*/

/**
 * @author luo
 * @description
 * @since 2022/7/25 17:05
 */
public class Rob {

    @Test
    public void example1() {
        int result = rob(new int[]{1, 2, 3, 1});
        System.out.println("最大价值为：" + result);
        Assertions.assertEquals(4, result);
    }

    @Test
    public void example2() {
        int result = rob(new int[]{2, 1, 1, 2});
        System.out.println("最大价值为：" + result);
        Assertions.assertEquals(4, result);
    }

    @Test
    public void example3() {
        int result = rob(new int[]{1, 2});
        System.out.println("最大价值为：" + result);
        Assertions.assertEquals(2, result);
    }

    int[] nums;
    int[] cache;

    public int rob(int[] nums) {
        this.nums = nums;
        cache = new int[nums.length];
        Arrays.fill(cache, Integer.MIN_VALUE);
        return Math.max(rob(0),rob(1));
    }

    int rob(int index) {

        if (index >= nums.length - 1) {
            if (index == nums.length - 1) {
                return nums[index];
            }
            return 0;
        }
        int cacheResult = cache[index];
        if (cacheResult != Integer.MIN_VALUE) {
            return cacheResult;
        }
        int sum2 = rob(index + 2);
        int sum3 = rob(index + 3);

        return cache[index] = Math.max(sum2, sum3) + nums[index];
    }
}
